# **Computer Architecture**

CA4

RISC-V Pipeline

Mohammad Moshiri Balasoor - 810101518 Narges Elyasi - 810100258

1403.03.28

Table 3: RV32I RISC-V Integer instructions

| ор                   | Func3 | Func7   | Туре | Mnemonic                      | Description                         | Operation                                       |
|----------------------|-------|---------|------|-------------------------------|-------------------------------------|-------------------------------------------------|
| 0000011(3)           | 000   |         | I    | lb rd, imm(rs1)               | Load byte                           | rd = SignExt([Address]7:0)                      |
| 0000011(3)           | 001   |         | I    | lh rd, imm(rs1)               | Load half                           | rd = SignExt([Address] <sub>15:0</sub> )        |
| 0000011(3)           | 010   |         | I    | lw rd, imm(rs1)               | Load word                           | rd = ([Address] <sub>31:0</sub> )               |
| 0000011(3)           | 100   |         | I    | lbu rd, imm(rs1)              | Load byte unsigned                  | rd = ZeroExt([Address]7:0)                      |
| 0000011(3)           | 101   |         | I    | lhu rd, imm(rs1)              | Load half unsigned                  | rd = ZeroExt([Address] <sub>15:0</sub> )        |
| 0010011(19)          | 000   |         | I    | addi rd, rs1, imm             | ADD immediate                       | rd = rs1 + SignExt(imm)                         |
| 0010011(19)          | 001   |         | I    | slli rd, rs1, uimm            | Shift left logical immediate        | rd = rs1 << uimm                                |
| 0010011(19)          | 010   |         | I    | slti rd, rs1, imm             | Set less than immediate             | rd = rs1 < SignExt(imm)                         |
| 0010011(19)          | 011   | 0000000 | I    | sltiu rd, rs1, imm            | Set less than imm. unsigned         | rd = rs1 < SignExt(imm)                         |
| 0010011(19)          | 100   |         | I    | xori rd, rsl, imm             | XOR immediate                       | rd = rs1 ^ SignExt(imm)                         |
| 0010011( <b>19</b> ) | 101   | 0000000 | I    | srli rd, rs1, uimm            | Shift right logical immediate       | rd = rs1 >> uimm                                |
| 0010011(19)          | 101   | 0100000 | I    | srai rd, rs1, uimm            | Shift right arithmetic immediate    | rd = rs1 >> uimm                                |
| 0010011(19)          | 110   |         | I    | ori rd, rs1, uimm             | OR immediate                        | rd = rs1   SignExt(imm)                         |
| 0010011( <b>19</b> ) | 111   |         | I    | andi rd, rs1, uimm            | AND immediate                       | rd = rs1 & SignExt(imm)                         |
| 0010111(23)          |       |         | U    | auipc rd, rsl, uimm           | ADD upper immediate to PC           | rd = (upimm, 12'b0) + PC                        |
| 0100011(35)          |       |         | S    | sb rs2,imm(rs1)               | Store byte                          | [Address] <sub>7:0</sub> = rs2 <sub>7:0</sub>   |
| 0100011(35)          |       |         | S    | sh rs2,imm(rs1)               | Store half                          | [Address] <sub>15:0</sub> = rs2 <sub>15:0</sub> |
| 0100011(35)          |       |         | S    | sw rs2,imm(rs1)               | Store word                          | [Address] <sub>31:0</sub> = rs2                 |
| 0110011(51)          | 000   | 0000000 | R    | add rd, rs1, rs2              | ADD                                 | rd = rs1 + rs2                                  |
| 0110011(51)          | 000   | 0100000 | R    | sub rd, rs1, rs2              | SUB                                 | rd = rs1 - rs2                                  |
| 0110011(51)          | 001   | 0000000 | R    | sll rd, rs1, rs2              | Shift left logical                  | rd = rs1 << rs2 <sub>4:0</sub>                  |
| 0110011(51)          | 010   | 0000000 | R    | slt rd, rs1, rs2              | Set less than                       | rd = rs1 < rs2                                  |
| 0110011(51)          | 011   | 0000000 | R    | sltu rd, rs1, rs2             | Set less than unsigned              | rd = rs1 < rs2                                  |
| 0110011(51)          | 100   | 0000000 | R    | xor rd, rs1, rs2              | XOR                                 | rd = rs1 ^ rs2                                  |
| 0110011(51)          | 101   | 0000000 | R    | srl rd, rs1, rs2              | Shift right logical                 | rd = rs1 >> rs2 <sub>4:0</sub>                  |
| 0110011(51)          | 101   | 0100000 | R    | sra rd, rs1, rs2              | Shift right arithmetic              | rd = rs1 >>>rs2 <sub>4:0</sub>                  |
| 0110011(51)          | 110   | 0000000 | R    | or rd, rs1, rs2               | OR                                  | rd = rs1   rs2                                  |
| 0110011(51)          | 111   | 0000000 | R    | and rd, rs1, rs2              | AND                                 | rd = rs1 & rs2                                  |
| 0110111(55)          | -     |         | U    | lui rd, upimm                 | Load upper immediate                | rd = {upimm, 12'b0}                             |
| 1100011(99)          | 000   |         | В    | beq rs1,rs2, label            | Branch if equal =                   | if (rs1 == rs2) PC = BTA                        |
| 1100011(99)          | 001   |         | В    | <pre>bne rs1,rs2, label</pre> | Branch if not equal ≠               | if (rs1 != rs2) PC = BTA                        |
| 1100011(99)          | 010   |         | В    | blt rs1,rs2, label            | Branch if lower than <              | if (rs1 < rs2) PC = BTA                         |
| 1100011(99)          | 011   |         | В    | bge rs1,rs2, label            | Branch if greater / equal ≥         | if (rs1 ≥ rs2) PC = BTA                         |
| 1100011(99)          | 100   |         | В    | bltu rs1,rs2, label           | Branch if lower than unsigned <     | if (rs1 < rs2) PC = BTA                         |
| 1100011(99)          | 101   |         | В    | bgeu rs1,rs2, label           | Branch if greater / equal unsign. ≥ | if (rs1 ≥ rs2) PC = BTA                         |
| 1100111(103)         | 000   |         | I    | jalr rd, rs1, label           | Jump and link register              | PC = rs1 + SignExt(imm)<br>rd = PC + 4          |
| 1101111(111)         | -     |         | J    | jal rd, label                 | Jump and link                       | PC = JTA $rd = PC + 4$                          |

# Datapath



# Controller

| Instruction<br>Type | Instruction | PCsrc | Result src | Mem<br>write | ALU op | ALU<br>control | ALU src | imm src | Reg<br>write | Branch | jal | jalr |
|---------------------|-------------|-------|------------|--------------|--------|----------------|---------|---------|--------------|--------|-----|------|
| R-Type              | add         | 00    | 00         | 0            | 10     | 000            | 0       | XXX     | 1            | 0      | 0   | 0    |
|                     | sub         | 00    | 00         | 0            | 10     | 001            | 0       | XXX     | 1            | 0      | 0   | 0    |
|                     | and         | 00    | 00         | 0            | 10     | 010            | 0       | XXX     | 1            | 0      | 0   | 0    |
|                     | or          | 00    | 00         | 0            | 10     | 011            | 0       | XXX     | 1            | 0      | 0   | 0    |
|                     | slt         | 00    | 00         | 0            | 10     | 101            | 0       | XXX     | 1            | 0      | 0   | 0    |
|                     | sltu        | 00    | 00         | 0            | 10     | 110            | 0       | XXX     | 1            | 0      | 0   | 0    |
| l-Type              | lw          | 00    | 01         | 0            | 00     | 000            | 1       | 000     | 1            | 0      | 0   | 0    |
|                     | addi        | 00    | 00         | 0            | 11     | 000            | 1       | 000     | 1            | 0      | 0   | 0    |
|                     | xori        | 00    | 00         | 0            | 11     | 100            | 1       | 000     | 1            | 0      | 0   | 0    |
|                     | ori         | 00    | 00         | 0            | 11     | 011            | 1       | 000     | 1            | 0      | 0   | 0    |
|                     | slti        | 00    | 00         | 0            | 11     | 101            | 1       | 000     | 1            | 0      | 0   | 0    |
|                     | sltiu       | 00    | 00         | 0            | 11     | 110            | 1       | 000     | 1            | 0      | 0   | 0    |
|                     | jalr        | 10    | 10         | 0            | 11     | 000            | 1       | 000     | 1            | 0      | 0   | 1    |
| S-Type              | SW          | 00    | XX         | 1            | 00     | 000            | 1       | 001     | 0            | 0      | 0   | 0    |
| J-Type              | jal         | 01    | 10         | 0            | XX     | 000            | Χ       | 010     | 1            | 0      | 1   | 0    |
| B-Type              | beq         | **    | XX         | 0            | 01     | 001            | 0       | 011     | 0            | 1      | 0   | 0    |
|                     | bne         | **    | XX         | 0            | 01     | 001            | 0       | 011     | 0            | 1      | 0   | 0    |
|                     | blt         | **    | XX         | 0            | 01     | 001            | 0       | 011     | 0            | 1      | 0   | 0    |
|                     | bge         | **    | XX         | 0            | 01     | 001            | 0       | 011     | 0            | 1      | 0   | 0    |
| U-Type              | lui         | 00    | 11         | 0            | XX     | 000            | X       | 100     | 1            | 0      | 0   | 0    |

<sup>\*\*</sup> PCsrc for B-Type instruction : IF branch\_resault == 1 THEN PCsrc = 01 ELSE PCsrc = 00

#### Test:

```
nums = [-34, -10, 37, 46, 98, 2, 131, -982, 143, 8, 56, 36, -28, 98, 17, -7, 0, 2, 5, 91]
```

#### **Data Memory:**

### 000003e0 xxxxxxxx xxxxxxx xxxxxxx xxxxxxx 000003e4 xxxxxxxx xxxxxxx xxxxxxx xxxxxxx 000003e8 |11011110 11111111 11111111 11111111 000003ec |11110110 11111111 11111111 11111111 000003f0 |00100101 00000000 00000000 00000000 000003f4 00101110 00000000 00000000 00000000 000003f8 | 01100010 00000000 00000000 00000000 000003fc 00000010 00000000 00000000 00000000 00000408 10001111 00000000 00000000 00000000 0000040c 00001000 00000000 00000000 00000000 00000418 11100100 11111111 11111111 11111111 0000041c 01100010 00000000 00000000 00000000 00000420 00010001 00000000 00000000 00000000 00000424 111111001 11111111 11111111 11111111 00000428 00000000 00000000 00000000 00000000 0000042c 00000010 00000000 00000000 00000000 00000430 00000101 00000000 00000000 00000000 00000434 01011011 00000000 00000000 00000000 00000438 XXXXXXXX XXXXXXX XXXXXXX XXXXXXX 0000043c XXXXXXXX XXXXXXX XXXXXXX XXXXXXX

#### **Instruction Memory (for unsigned):**

```
00111110 10000000 00100100 00000011
00000004
00000008 00000000 00000000 00000100 10110011
0000000c 00000000 01000100 10000100 10010011
00000014 00000000 00000011 00001100 01100011
00000018 00111110 10000100 10101001 00000011
00000020 111111110 00000011 00000110 11100011
00000024 00000000 00001001 00000100 00110011
00000028 111111110 01011111 11110000 01101111
0000002c 01111100 10000000 00101000 00100011
00000030 | 00000000 01000000 00000000 01101111
00000034 XXXXXXXX XXXXXXX XXXXXXX XXXXXXX
00000038 XXXXXXXX XXXXXXX XXXXXXX XXXXXXX
```

## Signed numbers:

## **Assembly code:**

```
global _boot
.text
_boot:
   jal x0, FindMax
   FindMax:
       lw x8, 1000(x0)
       add x9, x0, x0
       Loop:
          addi x9, x9, 4
          slti x6, x9, 40
          beq x6, x0, EndLoop #* if 10 elements are traversed, jump to EndLoop
          slt x6, x8, x18
                                #* check if element is greater than maxElement
          beq x6, x0, Loop
                                #* if element is not greater than maxElement, jump to Loop
          add x8, x18, x0
          jal x0,Loop
       EndLoop:
          sw x8, 2000(x0)
          jal x0,End
   End:
```

### Registr file:

| 00000000  | 000000000000000000000000000000000000000 |
|-----------|-----------------------------------------|
| 00000001  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 00000002  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 00000003  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxx           |
| 00000004  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 00000005  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 00000006  | 000000000000000000000000000000000000000 |
| 00000007  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx |
| 80000000  | 000000000000000000000000001111          |
| 00000009  | 000000000000000000000000000000000000000 |
| 00000000a | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| d0000000b | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 0000000c  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| D0000000d | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 0000000e  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 0000000f  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 00000010  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 00000011  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 00000012  | 000000000000000000000000000000000000000 |
| 00000013  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 00000014  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 00000015  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 00000016  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 00000017  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx         |
| 00000018  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx          |
| 00000019  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx         |
| 0000001a  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx         |
| 0000001b  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx         |
| 0000001c  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx         |
| 0000001d  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx         |
| 0000001e  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx         |
| 0000001f  | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx         |
| I         | I                                       |